 //这里相当于callback=changeColor();
 function animate(obj, target, callback) {
     //一开始清除一下定时器，以防止多次点击之后，定时器会不断累加
     clearInterval(obj.timer);
     //给不同的对象开辟不同的timer(定时器)
     obj.timer = setInterval(function() {
         //让该元素的left随着时间的进行增加。
         //每次移动的步长=(目标值-现在的位置)/10
         //Math.ceil()是往大取整，若是负数则会出现bug
         //Mat.floor()是往小取整，适用于负数的情况
         var step = (target - obj.offsetLeft) / 10;
         //往右往左移动的时候，要进行判断步长
         step = step > 0 ? Math.ceil(step) : Math.floor(step);
         obj.style.left = obj.offsetLeft + step + 'px';
         if (obj.offsetLeft == target) {
             clearInterval(obj.timer);
             //  if (callback) {
             //      //调用一次回调函数
             //      callback();
             //  }
             callback && callback();
         }
     }, 15)
 }